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CIRCUIT-LEVEL MEMORY AND 
COMBINATIONAL BLOCK MODELING 

Inventor: Adrian J. Isles 

BACKGROUND OF THE INVENTION 
Field of the Invention 

The present invention relates to electronic design automation (EDA) 
systems. More particularly, the present invention relates to memory 
modeling for use with EDA tools. 

Description of the Related Art 

The design process for integrated circuits typically involves multiple 
transformations of a design from an initial idea to a functional, 
manufacturable product. A chip architect or designer begins with a design 
idea and then generates a corresponding behavioral definition of the design. 
The behavioral design results in a flow chart or a flow graph using which the 
designer can design the system data path and the registers and logic units 
necessary for implementation of the design. After the designer designs 
buses for coordinating and controlling the movement of data between 
registers and logic units, the data registers, buses, logic units, and their 
controlling hardware are implemented using logic gates and flip-flops. The 
result of this design stage is a netlist of gates and flip-flops. The netlist can 
be used to create a simulation model of the design to verify the design before 

Attorney Docket No.: HDAC-01 003US0 BBM/JAV 
jav/hdac/1 003/1 003.001 



provide the information needed by a routing software package to complete 
the actual design. The netlist of gates and flip-flops is thus transformed into 
a transistor list or layout and gates and flip-flops are replaced with their 
transistor equivalents or library cells. Timing and loading issues are also 
addressed during this cell and transistor selection process. Finally, the 
manufacturing process begins when the transistor list is implemented in a 
programmable logic device such as an FPGA or when the layout specification 
is used to generate masks for integrated circuit fabrication. 

EDA tools improve upon this design process by permitting electronic 
circuit designers to more quickly and inexpensively design and verify their 
designs. Figure 1 illustrates a typical design approach using EDA tools. The 
designer initially supplies a logic synthesis tool 120 with a high level 
language description 110 of the design and the logic synthesis tool 120 
reduces the high level language description 110 to a low level or gate level 
description 130 of the design. Finally, verification or simulation of the design 
is performed by an engine 140 using a set of properties 150 or behaviors as 
an input to determine whether, and to what extent, the design described by 
HDL description 110 satisfies the properties 150. The properties 150 are 
based on a functional specification for the design being verified or simulated. 
A more detailed discussion of design verification and the use of properties 
can be found in U.S. Patent Application Serial No. 09/447,085, filed 
November 22, 1999, entitled "Static Coverage Analysis," incorporated herein 
by reference. 
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The description of the design idea is typically written in a high-level 
hardware description language ("HDLs") such as VHDL or Verilog. HDLs 
provide formats for representing the output of the various design stages 
described above and are thus used to create circuits at various levels of 
abstraction including gate-level descriptions of functional blocks and high- 
level descriptions of complete systems. HDLs provide a convenient format 
for the representation of functional and wiring details of designs and may 
represent various hardware components at one or more levels of abstraction. 
HDLs can be used to model many different kinds of hardware components or 
electronic circuits. VHDL and Verilog are commonly used to model circuits 
ranging from ALUs, arithmetic blocks, bus arbiters, bus interfaces, cache 
controllers, data paths, dual-phase clocks, instruction and address decoders, 
pipelines, reset circuits, sequencers, and state machines. 

The design approach of Figure 1 has also been previously used to 
model, synthesize, and verify memory circuit designs. However, prior art 
memory models suffered from two major disadvantages. First, they modeled 
every location of the memory even if only a subset of locations of the 
memory were actually used by the design. For example, if the designer is 
modeling a RAM having, for example, 1024 locations, the designer must 
provide a functional description for each location of the memory even if the 
design only accessed a small portion of the memory locations. The resulting 
memory model was inefficient and wasted valuable design resources. 
Second, memory models from one EDA tools vendor can typically only be 

Attorney Docket No.: HDAC-01003USO BBM/JAV 
jav/hdac/1 003/1 003.001 



used with simulation or verification engines from the same vendor. In other 
words, the choice to use a particular prior art memory model necessitated a 
particular verification or simulation engine. This lack of interoperability 
greatly limits the utility of prior art memory models. 

Accordingly, there is a need for a means for modeling physical memory 
that more efficiently describes only those portions of a physical memory that 
are used by a given design. There is a further need for a memory model that 
is independent of the underlying simulation or verification engine and is thus 
interoperable with various simulation or verification engines. 

SUMMARY OF THE INVENTION 
The present invention, roughly described, provides a method for 
modeling a physical memory for use in an electronic circuit design where 
memory write operations to the physical memory and memory read 
operations from the physical memory are modeled in a lookup table. The size 
or the number of entries in the lookup table is limited by a total number of 
memory operations that can occur over a given number of clock cycles. In 
one embodiment, the upper bound is equal to the total number of memory 
operations that can be performed per clock cycle times the number of clock 
cycles plus any number of memory read operations specified in the 
properties. In another embodiment, the contents of the lookup table can, at 
any time, be initialized to a constant value or to an arbitrary initial value. 
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The present invention can be implemented using software, hardware, 
or a combination of software and hardware. When all or portions of the 
present invention are implemented in software, that software can reside on a 
processor readable storage medium. Examples of an appropriate processor 
5 readable storage medium include a floppy disk, hard disk, CD-ROM, memory 
IC, etc. The hardware used to implement the present invention includes an 
output device (e.g. a monitor or printer), an input device (e.g. a keyboard, 
pointing device, etc.), a processor in communication with the output device 
and processor readable storage medium in communication with the 
10 processor. 

The processor readable storage medium stores code capable of 
programming the processor to perform the steps to implement the present 
invention. In one embodiment, the present invention may comprise a 
dedicated processor including processor instructions for performing the steps 

15 the implement the present invention. In another embodiment, the present 
invention can be implemented on a web page on the Internet or on a server 
that can be accessed over communication lines. These and other objects and 
advantages of the invention will appear more clearly from the following 
detailed description in which the preferred embodiment of the invention has 

20 been set forth in conjunction with the drawings. 

BRIEF DESCRIPTION OF THE DRAWINGS 
Figure 1 is a block diagram overview of a prior art EDA tool. 
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Figure 2 is a flowchart of a memory write operation in accordance with 
the present invention. 

Figure 3 is a flowchart of a memory read operation in accordance with 
the present invention. 

Figure 4 is an exemplar memory write operation according to the 
memory model of the present invention. 

Figure 5 is an exemplar memory read operation according to the 
memory model of the present invention. 

Figure 6 is a block diagram illustrating the memory model of the 
present invention as used in an existing EDA tool. 

Figure 6A illustrates another embodiment of the present invention. 

Figure 6B is a flowchart illustrating another embodiment of the present 
invention. 

Figure 7 is a high level block diagram of an exemplar general purpose 
computer system which can be used to implement the present invention. 

DETAILED DESCRIPTION 
Figure 2 illustrates a memory model that can be implemented as 
lookup table 250, for use in modeling a physical memory 210 of an electronic 
circuit design. While physical memory 210 contains "i" locations, data has 
been written to only four of those locations. In physical memory 210, for 
example, the electronic circuit design has written a plurality of write data bits 
represented by D2 to write address A2. A plurality of write data bits 
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represented by D4 have been written to write address A4, A plurality of write 
data bits represented by Dg have been written to write address A5. A 
plurality of write data bits represented by Dj have been written to write 
address A,, Rather than modeling all "\" locations of physical memory 210, 
the present invention models only those locations of physical memory 210 
that have been accessed by the electronic circuit design. Lookup table 250 
is created to perform this task. Lookup table 250 comprises an address field 
255, a data field 260, and a valid bit field 265. While not drawn, lookup 
table 250 may also include a write enable bit that can be asserted to signify 
a memory write operation. It should also be noted that all valid bits of 
lookup table 250 in valid bit field 265 are initially in an unasserted logic 
state. 

The total number of entries in lookup table 250 ("n'") is defined by the 
total number of memory operations that can occur over a given number of 
clock cycles. More specifically, the total number of entries in lookup table 
250 is greater than or equal to the total number of memory operations that 
can occur in physical memory 210 over a given number of clock cycles (or 
over the period of time in which physical memory 210 is modeled or over the 
period in which the electronic circuit comprising physical memory 210 is 
simulated or verified). 

This upper bound is computed by determining the number of read and 
write ports of the physical memory that is to be modeled, determining a total 
number of memory operations that can be performed per clock cycle, and 
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multiplying the total number of memory operations per clock cycle with the 
number of clock cycles. For example, if the physical memory that is to be 
modeled contains two read ports and two write ports, then a maximum of 
four memory operations can occur in each clock cycle (i.e., two times two). 
5 Thus, if the period of time over which the physical memory is to be modeled 
is, for example, five cycles, then the total number of memory operations that 
can occur over this period of time is twenty (i.e., four memory operations per 
clock cycle times five cycles), 

It should be noted that this upper bound can also be affected by 

10 additional memory read operations that may be specified in one or more 
properties 1 50 of Figure 1 . In such a case, the number of additional memory 
read operations would have to be added to the total number of memory 
operations previously calculated. For example, if a given property specified, 
for example, two additional memory read operations, then the total number 

15 of memory read that can occur over the period of time in which the physical 
memory is modeled is twenty-two (i.e., twenty plus two). 

The first steps in modeling a memory write operation, WRITE(WADDR, 
WDATA), to physical memory 210 includes the steps of receiving write 
addresses (WADDR) of physical memory 210 to which data (WDATA) has 

20 been written, receiving WDATA written to physical memory 210 at the 
respective write addressees, and asserting a write enable signal. The next 
step is to check each entry in lookup table 250 to find an entry where the 
valid bit is asserted and the corresponding address in address field 255 in 
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lookup table 250 of the entry is equivalent to the WADDR. If such an entry 
exists, WDATA is written to data field 260 of that entry. However, if such 
an entry in lookup table 250 does not exist, the present invention finds an 
entry in lookup table 250 with an unasserted valid bit and places WADDR in 
5 address field 255 of that entry and WDATA is placed in data field 260 of 
that entry. 

Consider, for example, memory write operation 215 to physical 
memory 210, WRITE{A2, D2), where A2 represents a write address and D2 
f3 represents data being written to that write address. Given the write address 

y 10 (A2), the write data {D2), and the assertion of a write enable bit, the first step 
p in modeling this memory write operation to physical memory 210 is to check 

2 each entry in lookup table 250 to find an entry where the valid bit is asserted 

P and the address in the address field of that entry matches the write address 

S (A2). In this case, D2 is written to data field 260 of entry number 1 of lookup 

!;! 15 table 250 since the valid bit of entry number 1 is asserted and A2 is 
contained in address field 255 of entry number 1 , Memory write operations 
220 and 225 to physical memory 210 can be similarly modeled. That is, 
since the valid bit of entry number 2 is asserted and write address A4 is 
found in address field 255 of entry number 2, the previous contents in data 
20 field 260 of entry number 2 are overwritten with write data D4. Also, since 
the valid bit of entry number 3 of lookup table 250 is asserted and write 
address A5 is found in address field 255 of entry number 3, write data D5 is 
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written to the data field 260 of entry number 3 (therein overwriting any data 
that may have previously been in data field 260 of entry number 3). 

Consider now memory operation 230 in which write data D; is written 
to write address A, of physical memory 210. If after searching through all 
5 the entries in lookup table 250 and there are no entries where the valid bit is 
asserted and the corresponding address in address field 255 is equal to Aj, 
then the present invention, for example, finds an entry "r\'\ where the valid 
bit is unasserted and places the write address Aj in address field 255 of entry 
"n"r the write data D, in data field 260 of entry ''n," and asserts the valid bit 

10 of entry "n". All memory write operations to physical memory 210 can thus 
be modeled in lookup table 250. 

Figure 3 illustrates an exemplar memory read operation in accordance 
with the memory model of the present invention. The steps for modeling a 
memory read operation to physical memory 210 are similar to those of the 

15 memory write operation. Given a particular read address, RADDR, the 
present invention searches lookup table 250 for entries where the valid bit is 
asserted and address field 255 for that entry contains the RADDR. If such 
an entry exists in lookup table 250, the present invention returns the data in 
data field 260 corresponding to that entry. However, if such an entry is not 

20 found in lookup table 250, the present invention first finds an entry in lookup 
table 250 where the valid bit is unasserted. Next, the read address RADDR 
is placed in address field 255 of that entry and an arbitrary data value is 
assigned to data field 260 of that entry. The valid bit of that entry is then 
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asserted and the arbitrary date value assigned to data field 260 is then 
returned. In one embodiment of the present invention, an initial value to 
which the contents of lookup table 250 have been previously initialized may 
be returned instead of the arbitrary data value. 
5 Consider, for example, memory read operation 310, READ(A2), where 

the contents of the memory location in physical memory 210 identified by 
read address A2 are now being read. The present invention models memory 
read operation 310 by first searching each entry in lookup table 250 for an 
entry where the valid bit is asserted and address field 255 of that entry 

10 contains read address A2- In this example, the valid bit of entry 1 is asserted 
and address field 255 of entry 1 contains read address A2. The contents of 
data field 260 of entry number 1, D2, are thus returned. The present 
invention similarly models memory read operation 320, READCAg), by first 
searching lookup table 250 for an entry where the valid bit is asserted and 

1 5 address field 255 of that entry contains read address A5. Entry number 3 of 
lookup table 250 satisfies these conditions and the contents of data field 
260 of entry number 3, D^, are subsequently returned. 

Now consider memory read operation 315, READ{A3), where data 
corresponding to read address A3 is being read from physical memory 210. 

20 In this scenario, there are no entries in lookup table 250 where the valid bit is 
asserted and address field 255 contains read address A3. Consequently, the 
present invention models memory read operation 315 by first finding an entry 
in lookup table 250, entry ''n-1," where the valid bit is unasserted and 
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assigns read address A3 to address field 255 of entry number "n-1/' and 
assigns an arbitrary data value to data field 260 of entry number "n-1/' The 
present invention then asserts the valid bit for entry number ''n-1" and 
subsequently returns the arbitrary data value. As before, in one embodiment 
of the present invention, an initial value to which the contents of lookup 
table 250 may have previously initialized may be returned instead of the 
arbitrary data value. All memory read operations from physical memory 210 
can thus also be modeled by lookup table 250. 

Figure 4 is a flowchart of a memory write operation in accordance with 
the memory model of the present invention. In step 410, the memory write 
address, WADDR, and the write data, WDATA, corresponding to a memory 
write operation to physical memory 210 is first received. In step 415, lookup 
table 250 of Figures 2 and 3 is searched for entries where the valid bit is 
asserted and the corresponding address in the address field of that entry is 
equal to the write address WADDR. If such an entry in lookup table 250 
exists, write data WDATA is written to data field 260 corresponding to that 
entry in step 420. However, if there are no entries in lookup table 250 
where the valid bit is asserted and the corresponding address in address field 
255 is equal to write address WADDR, then, in step 425, the present 
invention finds an entry in lookup table 250 with an unasserted valid bit. In 
step 430, write address WADDR is placed in address field 255 of that entry. 
In step 435, write data WDATA is placed in data field 260 of that entry and 
the valid bit of that entry is asserted in step 440. These steps are performed 
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for each memory write operation to physical memory 210 and the resulting 
lookup table models all write operations to physical memory 210. 

Figure 5 is a flowchart of a memory read operation in accordance with 
the memory model of the present invention. Modeling a memory read 
operation from physical memory 210 begins in step 510 with read address 
RADDR being received. In step 515, the present invention searches lookup 
table 250 for entries where the valid bit is asserted and address field 255 
contains the read address RADDR. If such an entry in lookup table 250 
exists, the data in data field 260 of that entry is returned in step 520. 
However, if lookup table 250 does not contain an entry where the valid bit is 
asserted and address field 255 does not contain read address RADDR, then, 
in step 525, the present invention finds an entry in lookup table 250 with an 
unasserted valid bit. In step 530, read address RADDR is placed in address 
field 255 of that entry and, in step 535, an arbitrary data value is assigned to 
data field 260 of that entry. In step 540, the valid bit for that entry is 
asserted and, in step 545, the arbitrary data value in data field 260 of that 
entry is returned. These steps are performed for each memory read 
operation from physical memory 210 and the resulting lookup table 250 
models all read operations from physical memory 210. 

Figure 6 illustrates how the memory model of the present invention is 
used in an EDA tool. For a given electronic circuit design having a physical 
memory, the process of simulating/verifying the design begins with the 
creation of a circuit description 620 of the design. While this circuit 
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description could be an HDL description, any circuit description of the design 
will suffice. Circuit description 620 would then be inputted to logic 
synthesis tool 630. Logic synthesis tool 630 reduces circuit description 620 
to a gate level description 640 of the electronic circuit design. That portion 
5 of gate level description 640 relating to the physical memory is then replaced 
with lookup table 645 wherein lookup table 645 effectively models all read 
and write ports of the physical memory. That is, all memory write operations 
to the physical memory and all memory read operations from the physical 
memory are modeled in lookup table 645 in accordance with the steps 
10 outlined in Figures 4 and 5, respectively. Finally, verification or simulation of 
the electronic circuit design is performed by a verification or a simulation 
engine 650 together with a set of properties 660 or behaviors as an input to 
determine whether, and to what extent, the electronic circuit design satisfies 
properties 660. 

15 Thus, in accordance with the present invention, all read and write 

operations to and from any physical memory can be modeled by a lookup 
table. Aside from being a more efficient way to model only those locations 
of the physical memory that are accessed by a given design, there are two 
other significant advantages in using the lookup table approach of the 

20 present invention. First, the lookup table approach enables a physical 
memory to be modeled independent of the underlying simulation or 
verification engine. This is significant in that the lookup table approach of 
the present invention allows circuit designers and chip architects to create 
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memory models that can be used with ALL existing simulation or verification 
engines. 

Second, and perhaps more importantly. Figure 6A illustrates another 
embodiment of the present invention. The lookup table approach of the 
present invention can be used to model any uninterpreted combinational 
block 666 or any combinational function, having "m" inputs and "n" outputs, 
of a given design comprising a circuit element 664 and a circuit element 668. 
In other words, the lookup table approach of the present invention can be 
used to model so called "black boxes" or uninterpreted portions of a design. 
An uninterpreted combinational block 666 or a combinational function can be 
modeled using a lookup table in much the same way that a memory read 
operation from physical memory 210 is modeled in lookup table 250 (see 
Figures 3 and 5). The only difference is that the read address is now the 
argument(s) of the combinational functions. 

Figure 6B is a flowchart illustrating a method of modeling an 
uninterpreted combinational block or function using a lookup table. In step 
670, the lookup table is initialized. Step 670 may include the steps of 
initializing the contents of the lookup table to some initial value, and setting 
all valid bits of the lookup table to some initial state (e.g., unasserted). In 
step 672, the present invention searches the lookup table for entries where 
the valid bit is asserted and an ''address" field contains the argument(s) of 
the combinational block or function. 
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If such an entry in the lookup table exists, then, in step 676, the 
combinational block or function is modeled using a first set of process 
step{s). The first set of process step(s) may include a step where a data 
value corresponding to the argument is returned if an entry in the lookup 
5 table comprises the argument and a valid bit of that entry is asserted. 
However, if such an entry does not exist, then, in step 674, the 
combinational block or function is modeled using a second set of process 
step(s). The second set of process step(s) may include the steps where an 
entry in the lookup table with an unasserted valid bit is found, the argument 

10 is placed in the "address" field of that entry, an arbitrary data value is 
assigned to that entry corresponding to the argument, the valid bit of that 
entry is asserted, and the arbitrary data value is returned. In step 680, the 
resulting model of the uninterpreted combinational block can be provided as 
an input to a gate level description of the design. The design containing the 

1 5 uninterpreted combinational block can then be simulated or verified using an 
engine {not shown). 

For example, a combinational function, f(X), representing a given 
uninterpreted combinational block of a design where "X" is the argument of 
the function, can be modeled In a lookup table using a READ(X) operation. 

20 As with the memory write operation described in Figures 3 and 5, for a given 
clock cycle, a READ(X) operation will return a data value corresponding to 
argument "X" if an entry in the lookup table comprises argument "X" in an 
"address" field and a valid bit of that entry is asserted. If, however, no 
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entries in the lool<up table comprise argument "X" and an asserted valid bit, 
then argument "X" is placed in an entry of the lookup table with an 
unasserted valid bit, an arbitrary data value corresponding to argument "X" is 
returned, and the valid bit of that entry is asserted. 

This process is repeated for as many clock cycles as are required to 
verify or simulate the design containing the uninterpreted combinational 
block. While this exemplar function contains only one argument "X/' the 
lookup table approach of the present invention can be used to model 
combinational blocks or functions having multiple arguments. The resulting 
model of any uninterpreted combinational blocks or black boxes of a design 
will also be engine independent. That is, the resulting model can be used 
with all existing simulation or verification engines. 

Figure 7 illustrates a high-level block diagram of a general purpose 
computer system which can be used to implement the present invention. 
The computer system 710 of Figure 7 includes a processor unit 712 and 
main memory 714. Processor unit 712 may contain a single microprocessor, 
or may contain a plurality of microprocessors for configuring the computer 
system as a multi-processor system. Main memory 714 stores, in part, 
instructions and data for execution by processor unit 712. If the present 
invention is wholly or partially implemented in software, main memory 714 
stores the executable code when in operation. Main memory 714 may 
include banks of dynamic random access memory (DRAM) as well as high- 
speed cache memories. 
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The computer system 710 of Figure 7 further includes a mass storage 
device 716, peripheral device(s) 718, input device(s) 720, portable storage 
medium drive{s) 722, a graphics subsystem 724, an output display 726, and 
output devices 732. For purposes of simplicity, the components in computer 
5 system 710 are shown in Figure 7 as being connected via a single bus 728. 
However, computer system 710 may be connected through one or more data 
transport means. For example, processor unit 712 and main memory 714 
may be connected via a local microprocessor bus, and the mass storage 
device 716, peripheral device(s) 718, portable storage medium drive(s) 722, 

10 graphics subsystem 724, and output devices 732 may be connected via one 
or more input/output (I/O) buses. Mass storage device 716, which may be 
implemented with a magnetic disk drive or an optical disk drive, is a non- 
volatile storage device for storing data and instructions for use by processor 
unit 712. In one embodiment, mass storage device 16 stores the system 

15 software for determining a path for purposes of loading to main memory 
714. 

Portable storage medium drive 722 operates in conjunction with a 
portable non-volatile storage medium, such as a floppy disk, to input and 
output data and code to and from computer system 710. In one 
20 embodiment, the system software for determining a path is stored on such a 
portable medium, and is input to the computer system 710 via the portable 
storage medium drive 722. Peripheral device{s) 718 may include any type of 
computer support device, such as an input/output (I/O) interface, to add 
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additional functionality to the computer system 710. For example, peripheral 
device{s) 718 may include a network interface card for interfacing computer 
system 710 to a network, a modem, etc. 

Input device(s) 720 provide a portion of the user interface for a user of 
5 computer system 710. Input device(s) 720 may include an alpha-numeric 
keypad for inputting alpha-numeric and other key information, or a cursor 
control device, such as a mouse, a trackball, stylus, or cursor direction keys. 
In order to display textual and graphical information, computer system 710 
contains graphics subsystem 724 and the output display 726. Output 

10 display 726 may include a cathode ray tube (CRT) display, liquid crystal 
display (LCD) or other suitable display device. Graphics subsystem 724 
receives textual and graphical information, and processes the information for 
output to output display 726. 

Output display 726 can be used to report the results of a sign text 

1 5 computation. Output devices 732 provide another means for reporting the 
results of a sign text computation. Output devices 732 may include a 
printer, a personal digital assistant (PDA), a modem, a cellular telephone 
capable of transmitting and receiving text messages, audio speakers, or any 
other device to which the results of the sign text The components 

20 contained in computer system 710 are those typically found in general 
purpose computer systems, and are intended to represent a broad category 
of such computer components that are well known in the art. 
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The components contained in the computer system of Figure 7 are 
those typically found in general purpose computer systems, and are intended 
to represent a broad category of such computer components that are well 
known in the art. Thus, the computer system of Figure 7 can be a personal 
5 computer, workstation, minicomputer, mainframe computer, etc. The 
computer can also include different bus configurations, networked platforms, 
multi-processor platforms, etc. Various operating systems can be used 
including Unix, Linux, Windows, Macintosh OS, and other suitable operating 
systems. 

10 The foregoing description of preferred embodiments of the present 

invention has been provided for the purposes of illustration and description. 
It is not intended to be exhaustive or to limit the invention to the precise 
forms disclosed. Many modifications and variations will be apparent to 
practitioners skilled in this art. The described embodiments were chosen and 

15 described in order to best explain the principles of the invention and its 
practical application to thereby enable others skilled in the art to understand 
the invention for various embodiments and with various modifications as are 
suited to the particular use contemplated. It is intended that the scope of the 
invention be defined by the following claims and their equivalents. 

20 
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What is claimed is: 



1 1. A method for modeling a physical memory for use in an 

2 electronic design, the method comprising the steps of: 

3 modeling a memory write operation using a lookup table; and 

4 modeling a memory read operation using the lookup table. 

1 2, The method of claim 1, wherein the step of modeling a memory 

2 write operation comprises the steps of: 

3 receiving a plurality of write address bits corresponding to a write 

4 address of the physical memory to which a plurality of write data bits are 

5 written by the electronic design; 

6 receiving the plurality of write data bits corresponding to write data 

7 written to the physical memory at the write address; and 

8 determining whether the lookup table comprises a first entry that 

9 contains the plurality of write address bits in an address field and a valid bit 
10 of the first entry is asserted, 

1 3. The method of claim 2, wherein the step of modeling a memory 

2 write operation further comprises the step of: 

3 writing the plurality of write data bits to a data field of the first entry if 

4 the first entry contains the plurality of write address bits in the address field 

5 and a valid bit of the first entry is asserted. 



Attorney Docket No.: HDAC-01 003US0 BBM/JAV 
jav/hdac/1 003/1 003.001 



- 22 - 



1 4. The method of claim 2, wherein the step of modeling a memory 

2 Write operation further comprises the following steps if the first entry does 

3 not contain the plurality of write address bits in the address field and a valid 

4 bit of the first entry is not asserted: 

5 finding a second entry in the lookup table wherein a valid bit of the 

6 second entry is not asserted; 

7 writing the plurality of write address bits to an address field of the 

8 second entry; 

9 writing the plurality of write data bits to a data field of the second 

10 entry; and 

1 1 asserting the valid bit of the second entry. 



1 5. The method of claim 1, wherein the step of creating a memory 

2 read operation comprises the steps of: 

3 receiving a plurality of read address bits corresponding to a read 

4 address of the physical memory from which a plurality of read data bits are 

5 read by the electronic design; and 

6 determining whether the lookup table comprises a first entry that 

7 contains the plurality of read address bits in an address field and a valid bit of 

8 the first entry is asserted. 
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1 6. The method of claim 5, wherein the step of creating a memory 

2 read operation further comprises the step of: 

3 returning the plurality of read data bits from a data field of the first 

4 entry if the first entry contains the plurality of read address bits in the 

5 address field and a valid bit of the first entry is asserted. 

1 7. The method of claim 5, wherein the step of creating a memory 

2 read operation further comprises the following steps if the first entry does 

3 not contain the plurality of read address bits in the address field and a valid 

4 bit of the first entry is not asserted: 

5 finding a second entry in the lookup table wherein a valid bit of the 

6 second entry is not asserted; 

7 writing the plurality of read address bits to an address field of the 

8 second entry; 

9 assigning a plurality of read data bits corresponding to an arbitrary 

10 data value to a data field of the second entry; 

1 1 asserting the valid bit of the second entry; and 

1 2 returning the arbitrary data value, 

1 8. The method of claim 7, wherein the arbitrary data value 

2 represents an initial value of the plurality of read data bits after an 

3 initialization step. 
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1 9. The method of claim 1, wherein a number of entries in the 

2 lookup is limited by a total number of memory operations that can occur over 

3 a given number of clock cycles, the total number of memory operations being 

4 computed by the steps of: 

5 computing a total number of memory operations that can be performed 

6 per clock cycle; and 

7 multiplying the total number of memory operations that can be 

8 performed per clock cycle by the given number of clock cycles. 

1 10. The method of claim 9, further comprising the steps of: 

2 determining a number of memory read operations in a property; and 

3 adding the number of memory read operations in a property to the 

4 total number of memory operations. 

1 11. The method of claim 1 , further comprising the step of: 

2 initializing a plurality of bits in a data field of an entry of the lookup 

3 table to an initial value. 

1 1 2. A method for modeling an uninterpreted combinational block of 

2 an electronic circuit design in a lookup table, the uninterpreted combinational 

3 block being represented by a combinational function having an argument, the 

4 method comprising the steps of: 
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5 initializing the lookup table; 

6 receiving the argument; 

7 determining whether the lookup table comprises a first entry that 

8 contains the argument in an address field of the first entry and a valid bit of 

9 the first entry is asserted; and 

10 returning a data value in a data field of the first entry if the first entry 

1 1 contains the argument and the valid bit of the first entry is asserted, the data 

1 2 value being associated with the argument. 



1 13. The method of claim 12, further comprising the steps of writing 

2 the argument to an address field of a second entry having an unasserted 

3 valid bit, assigning an arbitrary data value to a data field of the second entry 

4 wherein the arbitrary data value is prospectively associated with the 

5 argument, asserting the valid bit of the second entry, and returning the 

6 arbitrary data value if the lookup table does not comprise a first entry that 

7 contains the argument in the address field of the first entry and the valid bit 

8 of the first entry is not asserted. 



1 14. A method for modeling a physical memory in an electronic 

2 circuit design, the method comprising the steps of: 

3 receiving a plurality of write address bits corresponding to a write 

4 address of the physical memory to which the electronic circuit design writes 

5 a plurality of write data bits; 
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6 receiving the plurality of write data bits written by the electronic circuit 

7 design to the physical memory at the write address; 

8 modeling a memory write operation in a memory model to represent a 

9 memory write operation in the physical memory; and 

10 determining whether the memory model comprises an entry that 

1 1 contains the plurality of write address bits in an address field and whether a 

1 2 valid bit of the entry is asserted. 



1 15. The method of claim 14, wherein the plurality of write data bits 

2 are written to a data field of the entry if the entry contains the plurality of 

3 write address bits in the address field and the valid bit of the entry is 

4 asserted. 



5 16. The method of claim 14, further comprising the following steps if 

6 the entry does not contain the plurality of write address bits in the address 

7 field and a valid bit of the entry is not asserted: 

8 finding a second entry in the memory model wherein a valid bit of the 

9 second entry is not asserted; 

10 writing the plurality of write address bits to an address field of the 

1 1 second entry; 

12 writing the plurality of write data bits to a data field of the second 

13 entry; and 

14 asserting the valid bit of the second entry. 
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1 17. The method of claim 14, further comprising the steps of: 

2 receiving a plurality of read address bits corresponding to a read 

3 address of the physical memory from which the electronic circuit design 

4 reads a plurality of read data bits; 

5 modeling a memory read operation in the memory model to represent a 

6 memory read operation in the physical memory; and 

7 determining whether the entry contains the plurality of read address 

8 bits in the address field and whether the valid bit of the entry is asserted. 

1 18. The method of claim 17, wherein the plurality of read data bits 

2 from a data field of the entry is returned if the entry contains the plurality of 

3 read address bits in the address field and the valid bit of the entry is 

4 asserted. 

1 19. The method of claim 17, further comprising the following steps 

2 if the entry does not contain the plurality of read address bits in the address 

3 field and a valid bit of the entry is not asserted: 

4 finding a second entry in the memory model wherein a valid bit of the 

5 second entry is not asserted; 

6 writing the plurality of read address bits to an address field of the 

7 second entry; 
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8 assigning a plurality of read data bits corresponding to an arbitrary 

9 value to a data field of the second entry; 

10 asserting the valid bit of the second entry; and 

1 1 returning the arbitrary value. 

1 20. The method of claim 14, wherein the memory model comprises 

2 a lookup table. 

1 21. The method of claim 20, wherein a total number of entries of 

2 the lookup table is greater than or substantially equal to a total number of 

3 memory operations that can occur over a given number of clock cycles, the 

4 total number of memory operations being computed by the steps of: 

5 determining a number of read ports of the physical memory; 

6 determining a number of write ports of the physical memory; 

7 computing a total number of memory operations that can be performed 

8 per clock cycle; and 

9 multiplying the total number of memory operations that can be 

1 0 performed per clock cycle with the given number of clock cycles, 

1 22. The method of claim 21, further comprising the steps of: 

2 determining a number of memory read operations in a property; and 

3 adding the number of memory read operations in a property to the 

4 total number of memory operations. 
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1 23. A method for modeling an electronic circuit design having a 

2 physical memory, the physical memory being represented by a lookup table, 

3 the method comprising the steps of: 

4 creating the lookup table, the lookup table having a total number of 

5 entries that is greater than or substantially equal to an upper limit; 

6 creating a hardware description language description of the memory 

7 model and a plurality of components of the electronic circuit design; 

8 synthesizing a gate level description of the memory model and the 

9 plurality of components of the electronic circuit design; 

10 verifying operation of the electronic circuit design using a set of 

1 1 properties. 



1 24, The method of claim 23, wherein the step of creating the 

2 memory model comprises the steps of: 

3 receiving a plurality of write address bits corresponding to a write 

4 address of the physical memory to which the electronic circuit design writes 

5 a plurality of write data bits; 

6 receiving the plurality of write data bits written by the electronic circuit 

7 design to the physical memory at the write address; 

8 receiving a plurality of read address bits corresponding to a read 

9 address of the physical memory from which the electronic circuit design 
1 0 reads a plurality of read data bits; 
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1 1 determining whether the lookup table comprises an entry that contains 

1 2 the plurality of read address bits in the address field and whether the valid bit 

13 of the entry is asserted; 

14 returning the plurality of read data bits from a data field of the entry if 

1 5 the entry contains the plurality of read address bits in the address field and a 

1 6 valid bit of the entry is asserted; 

1 7 determining whether the lookup table comprises an entry that contains 

1 8 the plurality of write address bits in an address field and whether a valid bit 

19 of the entry is asserted; and 

20 writing the plurality of write data bits to the data field of the entry if 

21 the entry contains the plurality of write address bits in the address field and 

22 the valid bit of the entry is asserted. 

1 25. The method of claim 24, further comprising the following steps 

2 if the entry does not contain the plurality of read address bits in the address 

3 field and a valid bit of the entry is not asserted: 

4 finding a second entry in the lookup table wherein a valid bit of the 

5 second entry is not asserted; 

6 writing the plurality of read address bits to an address field of the 

7 second entry; 

8 assigning a plurality of read data bits corresponding to an arbitrary 

9 value to a data field of the second entry; 

10 asserting the valid bit of the second entry; and 
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1 1 returning the arbitrary value. 

1 26. The method of claim 24, further comprising the following steps 

2 if the entry does not contain the plurality of write address bits in the address 

3 field and a valid bit of the entry is not asserted: 

4 finding a second entry in the memory model wherein a valid bit of the 

5 second entry is not asserted; 

6 writing the plurality of write address bits to an address field of the 

7 second entry; 

8 writing the plurality of write data bits to a data field of the second 

9 entry; and 

10 asserting the valid bit of the second entry. 

1 27. The method of claim 23, wherein the upper limit represents a 

2 total number of memory operations that can occur over a given number of 

3 clock cycles, the total number of memory operations being computed by the 

4 steps of: 

5 determining a total number of memory read ports in the physical 

6 memory; 

7 determining a total number of memory write ports in the physical 

8 memory; 

9 computing a total number of memory operations that can be performed 
10 per clock cycle; 
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1 1 multiplying the total number of memory operations that can be 

1 2 performed per clock cycle with the given number of clock cycles. 

1 28- The method of claim 27, further comprising the steps of: 

2 determining a number of memory read operations performed in the set 

3 of properties; and 

4 adding the number of memory read operations performed in the set of 

5 properties to the total number of memory operations. 



1 29. A processor readable storage medium having processor readable 

2 code embodied on the processor readable storage medium, the processor 

3 readable code for programming a processor to perform a method for creating 

4 a memory model for use in modeling an electronic circuit design having a 

5 physical memory, the method comprising the steps of: 

6 modeling a memory write operation using a lookup table; and 

7 modeling a memory read operation using the lookup table, 

1 30. The processor readable storage medium of claim 29, wherein 

2 the step of modeling a memory write operation comprises the steps of: 

3 receiving a plurality of write address bits corresponding to a write 

4 address of the physical memory to which a plurality of write data bits are 

5 written by the electronic design; 
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6 receiving tlie plurality of write data bits written to the physical memory 

7 at the write address; 

8 determining whether the lookup table comprises a first entry that 

9 contains the plurality of write address bits in an address field and a valid bit 

10 of the first entry is asserted; and 

1 1 writing the plurality of write data bits to a data field of the first entry if 

1 2 the first entry contains the plurality of write address bits in the address field 

1 3 and the valid bit of the first entry is asserted. 



1 31. The processor readable storage medium of claim 30, wherein 

2 the step of modeling a memory write operation further comprises the 

3 following steps if the first entry does not contain the plurality of write 

4 address bits in the address field and a valid bit of the first entry is not 

5 asserted: 



6 finding a second entry in the lookup table wherein a valid bit of the 

7 second entry is not asserted; 

8 writing the plurality of write address bits to an address field of the 

9 second entry; 

10 writing the plurality of write data bits to a data field of the second 

1 1 entry; and 

1 2 asserting the valid bit of the second entry. 
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{ 32. The processor readable storage medium of claim 29, wherein 

2 the step of creating a memory read operation comprises the steps of: 

3 receiving a plurality of read address bits corresponding to a read 

4 address of the physical memory from which a plurality of read data bits are 

5 read by the electronic design; 

6 determining whether the lookup table comprises a first entry that 

7 contains the plurality of read address bits in an address field and a valid bit of 

8 the first entry is asserted; and 

9 returning the plurality of read data bits from a data field of the first 

10 entry if the first entry contains the plurality of read address bits in the 

1 1 address field and the valid bit of the first entry is asserted - 



1 33. The processor readable storage medium of claim 32, wherein 

2 the step of creating a memory read operation further comprises the following 

3 steps if the first entry does not contain the plurality of read address bits in 

4 the address field and the valid bit of the first entry is not asserted: 

5 finding a second entry in the lookup table wherein a valid bit of the 

6 second entry is not asserted; 

7 writing the plurality of read address bits to an address field of the 

8 second entry; 

9 assigning a plurality of read data bits corresponding to an arbitrary 
10 value to a data field of the second entry; 
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asserting the valid bit of the second entry; and 
returning the arbitrary value. 

34. An apparatus for creating a nnemory model for use in modeling 
an electronic design having a physical memory, the apparatus comprising: 
an output device; 

a processor, in communication with the output device; and 
a processor readable storage medium for storing code, the processor 
readable storage medium being in communication with the processor, the 
code capable of programming the processor to perform the steps of: 

receiving a plurality of write address bits corresponding to a 
write address of the physical memory to which the electronic circuit 
design writes a plurality of write data bits; 

receiving the plurality of write data bits written by the electronic 
circuit design to the physical memory at the write address; 

receiving a plurality of read address bits corresponding to a read 
address of the physical memory from which the electronic circuit 
design reads a plurality of read data bits; 

modeling a memory write operation using a memory model; 

modeling a memory read operation using the memory model; 

determining whether the memory model comprises an entry that 
contains the plurality of write address bits in an address field and 
whether a valid bit of the entry is asserted; and 
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it 



21 determining whether the entry contains the plurality of read 

22 address bits in the address field and whether the valid bit of the entry 

23 is asserted. 



1 35. The apparatus of claim 34, wherein the code capable of 

2 programming the processor performs the following steps if the entry does not 

3 contain the plurality of read address bits in the address field and a valid bit of 

4 the entry is not asserted: 

5 finding a second entry in the memory model wherein a valid bit of the 

6 second entry is not asserted; 

7 writing the plurality of read address bits to an address field of the 

8 second entry; 

9 assigning a plurality of read data bits corresponding to an arbitrary 

10 value to a data field of the second entry; 

1 1 asserting the valid bit of the second entry; and 

12 returning the arbitrary value. 



1 36. The apparatus of claim 34, wherein the code capable of 

2 programming the processor further comprises the step of: 

3 returning the plurality of read data bits from a data field of the entry if 

4 the entry contains the plurality of read address bits in the address field and 

5 the valid bit of the entry is asserted. 
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1 37. The apparatus of claim 34, wherein the code capable of 

2 programming the processor performs the following steps if the entry does not 

3 contain the plurality of write address bits in the address field and a valid bit 

4 of the entry is not asserted: 

5 finding a second entry in the memory model wherein a valid bit of the 

6 second entry is not asserted; 

7 writing the plurality of write address bits to an address field of the 

8 second entry; 

9 writing the plurality of write data bits to a data field of the second 

10 entry; and 

1 1 asserting the valid bit of the second entry. 



1 38. The apparatus of claim 34, wherein the code capable of 

2 programming the processor further comprises the step of: 

3 writing the plurality of write data bits to a data field of the entry if the 

4 entry contains the plurality of write address bits in the address field and the 

5 valid bit of the entry is asserted. 



1 39- The apparatus of claim 34, wherein the memory model 

2 comprises a lookup table. 
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1 40. The apparatus of claim 39, wherein a total number of entries of 

2 the lookup table is greater than or substantially equal to a total number of 

3 memory operations that can occur over a given number of clock cycles, the 

4 total number of memory operations being computed by the steps of: 

5 determining a number of read ports of the physical memory; 

6 determining a number of write ports of the physical memory; 

7 computing a total number of memory operations that can be performed 

8 by the electronic design per clock cycle; and 

9 multiplying the total number of memory operations that can be 
10 performed per clock cycle by the given number of clock cycles. 



1 41 . The apparatus of claim 40, further comprising the steps of: 

2 determining a number of memory read operations in a property, the 

3 property being a set of behaviors of the physical memory; and 

4 adding the number of memory read operations in a property to the 

5 total number of memory operations. 



1 42. An apparatus for creating a model of an uninterpreted 

2 combinational block of an electronic circuit design using a lookup table, the 

3 uninterpreted combinational block being represented by a combinational 

4 function having an argument, the apparatus comprising: 

5 an output device; 
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6 a processor, in communication with the output device; and 

• 7 a processor readable storage medium for storing code, the processor 

8 readable storage medium being in communication with the processor, the 

9 code capable of programming the processor to perform the steps of: 

10 receiving the argument; 

1 1 determining whether the lookup table comprises a first entry 

1 2 that contains the argument in an address field of the first entry and a 

1 3 valid bit of the first entry is asserted; and 

14 returning a data value in a data field of the first entry if the first 

15 entry contains the argument and the valid bit of the first entry is 
Oi 1 6 asserted, the data value being associated with the argument. 

l^, 1 43. The apparatus of claim 42, wherein the code capable of 

n 2 programming the processor further comprises the step of: 

O 3 initializing the lookup table. 

1 44. The apparatus of claim 42, wherein the code capable of 

2 programming the processor further comprises the steps of writing the 

3 argument to an address field of a second entry having an unasserted valid 

4 bit, assigning an arbitrary data value to a data field of the second entry 

5 wherein the arbitrary data value is prospectively associated with the 

6 argument, asserting the valid bit of the second entry, and returning the 

7 arbitrary data value if the lookup table does not comprise a first entry that 
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^ 8 contains the argument in the address field of the first entry and the valid bit 
' 9 of the first entry is not asserted. 
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ABSTRACT 

A method and apparatus for creating a memory model for use in 
modeling a physical memory of an electronic circuit design. Memory write 
operations to the physical memory and memory read operations are modeled 
in a lookup table. The number of entries in the lookup table is limited by an 
upper bound representing a total number of memory operations that can 
occur over a given number of clock cycles. 
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